<script
    lang="ts"
    generics="
        Context extends Exclude<keyof CobaltSettings, 'schemaVersion'>,
        Id extends keyof CobaltSettings[Context]
    "
>
    import settings, { updateSetting } from "$lib/state/settings";
    import type { CobaltSettings } from "$lib/types/settings";

    import Toggle from "$components/misc/Toggle.svelte";

    export let settingContext: Context;
    export let settingId: Id;

    export let title: string;
    export let description: string = "";

    $: setting = $settings[settingContext][settingId];
    $: isEnabled = !!setting;
</script>

<div id="setting-toggle-{settingContext}-{String(settingId)}" class="toggle-parent">
    <button
        class="toggle-container"
        role="switch"
        aria-checked={isEnabled}
        on:click={() =>
            updateSetting({
                [settingContext]: {
                    [settingId]: !isEnabled,
                },
            })
        }
    >
        <h4 class="toggle-title">{title}</h4>
        <Toggle enabled={isEnabled} />
    </button>
    <!--
        description is repeated here because there may be several toggles per settings category,
        and each of them needs its own description. this is intended. don't "clean it up".
    -->
    {#if description}
        <div class="subtext toggle-description">{description}</div>
    {/if}
</div>

<style>
    .toggle-parent {
        display: flex;
        flex-direction: column;
        gap: 8px;
        overflow: hidden;
    }

    .toggle-container {
        width: 100%;
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: var(--padding);
        justify-content: space-between;
        text-align: left;
        transform: none;
        padding: calc(var(--switcher-padding) * 2) 16px;
        border-radius: var(--border-radius);
        overflow: scroll;
    }
</style>
